

### Summary

Tutorial TU0117 (v1.5) October 31, 2006 This introductory tutorial is designed to give you an overview of how to create a schematic, update the design information to a PCB and generate manufacturing output files. It also investigates the concept of projects and integrated libraries.

Welcome to the world of Altium Designer – a complete electronic product development environment. This tutorial will get you started with creating a PCB project based on an astable multivibrator design.

If you are new to Altium Designer then you might like read the guide *Welcome to the Altium Designer Environment* for an explanation of the interface, information on how to use panels and managing design documents.

### **Creating a new PCB project**

A project in Altium Designer consists of links to all documents and setups related to a design. A project file, e.g. xxx.PrjPCB, is an ASCII text file that lists which documents are in the project and related output setups, e.g. for printing and CAM. Documents that are not associated with a project are called 'free documents'. Links to schematic sheets and a target output, e.g. PCB, FPGA, embedded (VHDL) or library package, are added to a project. Once the project is compiled, design verification, synchronization and comparison can take place. Any changes to the original schematics or PCB, for example, are updated in the project when compiled.

The process of creating a new project is the same for all project types. We will use the PCB project as an example. We will create the project file first and then create the blank schematic sheet to add the new empty project. Later in this tutorial we will create a blank PCB and add it to the project as well.

To start the tutorial, create a new PCB project:

 Select File » New » Project » PCB Project from the menus, or click on Blank Project (PCB) in the New section of the Files panel. If this panel is not displayed, click on the Files tab at the bottom of the Design Manager panel.

Alternatively, you could select **Printed Circuit Board Design** in the Pick a Task section of the Altium Designer Home Page (**View** » Home) and then click on **New Blank PCB Project**.

2. The **Projects** panel displays. The new project file, PCB\_Project1.PrjPCB, is listed here with no documents added.

| P | rojects                        |   | 🔻 🖉 🗙     |
|---|--------------------------------|---|-----------|
|   | Workspace1.DsnWrk              | • | Workspace |
|   | PCB_Project1.PrjPCB            |   | Project   |
|   | ● File View ○ Structure Editor |   | •ف ک      |
|   | E PCB_Project1.PrjPCB          |   |           |
|   | No Documents Added             |   |           |

3. Rename the new project file (with a .PrjPCB extension) by selecting File » Save Project As. Navigate to a location where you would like to store the project on your hard disk, type the name Multivibrator.PrjPCB in the File Name field and click on Save.

Next we will create a schematic to add to the empty project file. This schematic will be for an astable multivibrator circuit.

### Creating a new schematic sheet

Create a new schematic sheet by completing the following steps:

1. Select File » New » Schematic, or click on Schematic Sheet in the New section of the Files panel. A blank schematic sheet named Sheet1.SchDoc displays in the design window and the schematic document is automatically added (linked) to the project. The schematic sheet is now listed under Source Documents beneath the project name in the Projects tab.



 Rename the new schematic file (with a .SchDoc extension) by selecting File » Save As. Navigate to a location where you would like to store the schematic on your hard disk, type the name Multivibrator.SchDoc in the File Name field and click on Save.

When the blank schematic sheet opens you will notice that the workspace changes. The main toolbar includes a range of new buttons, new toolbars are visible, the menu bar includes new items and the **Sheet** panel is displayed. You are now in the Schematic Editor.

You can customize many aspects of the workspace. For example, you can reposition the panels and toolbars or customize the menu and toolbar commands.

Now we can add our blank schematic to the project before proceeding with the design capture.

### Adding schematic sheets to a project

If the schematic sheets you want to add to a project file have been opened as Free Documents, rightclick on the project name in the Projects panel and select **Add Existing to Project**. Choose the free documents name(s) and click **Open**. Alternatively, you could drag-and-drop the free document into the project documents list in the Projects panel. The schematic sheet is now listed under Source Documents beneath the project name in the Projects tab and is linked to the project file.

## Setting the schematic options

The first thing to do before you start drawing your circuit is to set up the appropriate document options. Complete the following steps.

- From the menus, choose Design » Document Options and the Document Options dialog will open. For this tutorial, the only change we need to make here is to set the sheet size to standard A4 format. In the Sheet Options tab, find the Standard Styles field. Click the arrow next to the entry to see a list of sheet styles.
- 2. Select the **A4** style and click the **OK** button to close the dialog and update the sheet size.
- 3. To make the document fill the viewing area again, select **View** » **Fit Document**.

In Altium Designer, you can activate any menu by simply pressing the menu hotkey (the underlined letter in the menu name). Any subsequent menu items will also have hot keys that you can use to activate the item. For example, the shortcut for selecting the **View** » **Fit Document** menu item is to press the **V** key followed by the **D** key. Many submenus, such as the **Edit** » **DeSelect** menu, can be called directly. To activate the **Edit** » **DeSelect** » **All on Current Document** menu item, you need only press the **X** key (to call up the DeSelect menu directly) followed by the **A** key.

Next we will set the general schematic preferences.

- Select Tools » Schematic Preferences [shortcut T, P] to open the schematic Preferences dialog. This dialog allows you to set global preferences that will apply to all schematic sheets you work on.
- Click on Schematic Default Primitives in the selection tree (left side of the dialog) to make it the active page and enable the Permanent check box. Click the OK button to close the dialog.
- Before you start capturing your schematic, save this schematic sheet, so select File » Save [shortcut F, S].

Altium Designer has a multilevel Undo, allowing you to undo any number of previous actions. The maximum number of Undo steps is userconfigurable and limited only by the available memory on your computer.

You can save any schematic sheet as a document template (.schdot) allowing you to include special information such as a custom company title block and logo.

## **Drawing the schematic**

You are now ready to begin capturing (drawing) the schematic. For this tutorial, we will use the circuit shown below (Figure 1). This circuit uses two 2N3904 transistors configured as a self-running astable multivibrator.



Figure 1. An astable multivibrator

### Locating the component and loading the libraries

To manage the thousands of schematic symbols included with Altium Designer, the Schematic Editor provides powerful library search features. Although the components we require are in the default installed libraries, it is useful to know how to search through the libraries to find components. Work through the following steps to locate and add the libraries you will need for the tutorial circuit.

First we will search for the transistors, both of which are type 2N3904.

- 1. Click on the **Libraries** tab to display the **Libraries** panel.
- Press the Search button in the Libraries panel, or select Tools » Find Component, to open the Libraries Search dialog.
- 3. Ensure that the Scope is set to Libraries on Path and that the Path field contains the correct path to your libraries. If you accepted the default directories during installation, the path should be C:\Program Files\Altium

| Libraries Sear                   | ch         |            | ?                                    | × |
|----------------------------------|------------|------------|--------------------------------------|---|
| *3904*                           |            |            |                                      |   |
| Options                          |            |            |                                      |   |
| Search type                      | Components |            | ▼                                    |   |
| 🔽 Clear existir                  | ng query   |            |                                      |   |
| Scope                            |            | Path       |                                      |   |
| 🔿 Available lit                  | oraries    | Path:      | M FILES\ALTIUM DESIGNER 6\Library\ 😝 |   |
| <ul> <li>Libraries or</li> </ul> | path       |            | Include Subdirectories               |   |
| O Refine last                    | search     | File Mask: | × × .                                |   |
| <u> </u>                         | 🗙 Clear 🛛  | Helper     | History Favorites Cancel             |   |

Designer 6\Library\. Click on the folder icon to browse to the library folder. Ensure that the **Include Subdirectories** box is not selected (not ticked) for this example.

4. We want to search for all references to 3904, so type \*3904\* in the query section at the top of the *Libraries Search* dialog. The \* symbol is a wildcard used to take into account the different prefixes and suffixes used by different manufacturers.

- 5. Click the **Search** button to begin the search. The Query Results are displayed in the **Libraries** panel as the search takes place.
- Click on the component name 2N3904 found in the Miscellaneous Devices.IntLib library to select it. This library has symbols for all the available simulationready BJT transistors.
- 7. If you choose a component that resided in a library that was not currently installed, you would be asked to confirm the installation of that library before you could place the component on your schematic. Since the Miscellaneous Devices library we need is already installed by default, the component is ready to place.

The added libraries will appear in the drop down list at the top of the Libraries panel. As you click on a library name in the upper list, the components in that library are listed below. The component filter in the panel can then be used to quickly locate a component within a library.

### Placing the components on your schematic

The first components we will place on the schematic are the two transistors, Q1 and Q2. For the general layout of the circuit, refer to the schematic drawing shown in Figure 1.

- 1. Select View » Fit Document [shortcut V, D] to ensure your schematic sheet takes up the full window.
- 2. Make sure the Libraries panel is displayed by clicking on the Libraries tab.
- 3. Q1 and Q2 are BJT transistors, so select the Miscellaneous Devices.IntLib library from the Libraries drop-down list at the top of the Libraries panel to make it the active library.
- 4. Use the filter to quickly locate the component you need. The default wildcard (\*) will list all components found in the library. Set the filter by typing \*3904\* in the filter field below the Library name. A list of components which have the text "3904" as part of their Component Name field will be displayed.
- 5. Click on the 2N3904 entry in the list to select it, then click the Place button. Alternatively, just double-click on the component name. The cursor will change to a cross hair and you will have an outlined version of the transistor "floating" on your cursor. You are now in part placement mode. If you move the cursor around, the transistor outline will move with it.
- Before placing the part on the schematic, first edit its properties. While the transistor is floating on the cursor, press the **TAB** key. This opens the *Component Properties* dialog for the component. We will now set up the dialog options to appear as below.

| Libraries     |                                   | <b>▼</b> ×                        |
|---------------|-----------------------------------|-----------------------------------|
| Libraries     | Search                            | Place 2N3904                      |
| Miscellaneous | Devices.IntLib                    | ¥                                 |
| *3904*        |                                   | ~                                 |
| Comp 🛆 D      |                                   | y Footprint<br>Ilaneous BCY-W3/E4 |
|               |                                   |                                   |
| 196 componer  | nts                               |                                   |
|               | Q?<br>2N39                        | 104                               |
|               | <u> </u>                          |                                   |
| Model Name    | Type 🛆                            | Source                            |
| 2N3904        | 3/E Footprint<br>Signal Integrity | Miscellaneous Device              |
| m 2N3904      |                                   | 2N3904.mdl                        |
|               |                                   |                                   |
|               |                                   | ~                                 |
|               |                                   | 3                                 |
|               |                                   | 1                                 |
|               |                                   | L                                 |
|               |                                   |                                   |

| roperties –                                                                 |                                                   |        |                          | P                                                    | arameters for Q? • 2N3904                            |                  |
|-----------------------------------------------------------------------------|---------------------------------------------------|--------|--------------------------|------------------------------------------------------|------------------------------------------------------|------------------|
| Designator                                                                  | Q? Visible                                        | Locked | Visible                  | Name                                                 | / Value                                              | Туре             |
| Comment                                                                     | 2N3904 Visible                                    |        |                          | Code_JEDEC                                           | TO-92A                                               | STRING           |
| omment                                                                      |                                                   | _      |                          | DatasheetDocument                                    | 1997                                                 | STRING           |
|                                                                             | Contraction Part 1/1                              | Locked |                          | LatestRevisionDate                                   | 15Jan-2003                                           | STRING           |
| ibrary Ref                                                                  | 2N3904                                            |        |                          | LatestRevisionNote                                   | PCB Footprint 'BCY-W3/D4.7' replace                  |                  |
|                                                                             | Miscellaneous Devices IntLib                      |        |                          | PackageReference                                     | T0-92A                                               | STRING           |
| .ibrary                                                                     | Miscellaneous Devices.IntLib                      |        |                          | Published                                            | 8-Jun-2000                                           | STRING           |
| escription                                                                  | NPN General Purpose Amplifier                     |        |                          | Publisher                                            | Altium Limited                                       | STRING           |
| Jnique Id                                                                   | WEMGYXLD                                          | Reset  |                          |                                                      |                                                      |                  |
| уре                                                                         | Standard                                          | ~      |                          |                                                      |                                                      |                  |
|                                                                             | 5                                                 |        |                          |                                                      |                                                      |                  |
| ub-Design L                                                                 | inks                                              |        |                          |                                                      |                                                      |                  |
| ub-Design L<br>ub-Project                                                   |                                                   |        |                          |                                                      |                                                      |                  |
| ub-Project                                                                  | None                                              |        | Add                      | Remo <u>v</u> e                                      | <u>E</u> dit Add as <u>R</u> ule                     |                  |
| ub-Project                                                                  | None                                              |        | <u>A</u> dd              |                                                      | Edit Add as <u>B</u> ule                             |                  |
| ub-Project<br>onfiguration<br>raphical                                      | None None                                         |        | Add                      |                                                      |                                                      |                  |
| ub-Project<br>onfiguration<br>raphical<br>.ocation X                        | None<br>None<br>740 Y 530                         |        | Name<br>2N3904           | Type<br>Simulation                                   | Models for Q? - 2N3904<br>C Description<br>NPN       |                  |
| ub-Project<br>onfiguration<br>raphical —<br>.ocation X<br>Drientation       | None<br>None<br>740 Y 530<br>0 Degrees Y Mirrored |        | Name<br>2N3904<br>2N3904 | Type<br>Simulation<br>Signal Integr                  | Models for Q? - 2N3904<br>C Description<br>NPN<br>ty |                  |
| ub-Project<br>onfiguration<br>raphical<br>.ocation X<br>Drientation<br>Mode | None<br>None<br>740 Y 530<br>0 Degrees V Mirrored |        | Name<br>2N3904           | Type<br>Simulation<br>Signal Integr                  | Models for Q? - 2N3904<br>C Description<br>NPN       | ds; Body Dia. 4. |
| ub-Project<br>onfiguration<br>raphical<br>.ocation X<br>Drientation<br>Mode | None<br>None<br>740 Y 530<br>0 Degrees Y Mirrored |        | Name<br>2N3904<br>2N3904 | Type<br>Simulation<br>Signal Integr<br>4 ▼ Footprint | Models for Q? - 2N3904<br>C Description<br>NPN<br>ty | ds; Body Dia. 4. |

- 7. In the **Properties** section of the dialog, set the value for the first component designator by typing Q1 in the **Designator** field.
- 8. Next we will check the footprint that will be used to represent the component in the PCB. For this tutorial, we have used integrated libraries which mean that the recommended models for footprints and circuit simulation are already included. Make sure that footprint name BCY-W3/E4 is included in the Models list. Leave all other fields at their default values and click **OK** to close the dialog.

You are now ready to place the part.

- Move the cursor (with the transistor symbol attached) to position the transistor a little left of the middle of the sheet. Once you are happy with the transistor's position, left-click or press ENTER to place the transistor onto the schematic.
- 2. Move the cursor and you will find that a copy of the transistor has been placed on the schematic sheet, but you are still in part placement mode with the part outline floating on the cursor. This feature of Altium Designer allows you to place multiple parts of the same type. So let's now place the second transistor. This transistor is the same as the previous one, so there is no need to edit its attributes before we place it. Altium Designer will automatically increment a component's designator when you place a series of parts. In this case, the next transistor we place will automatically be designated Q2.
- 3. If you refer to the schematic diagram (Figure 1) you will notice that Q2

The link between the schematic component and the PCB component is the footprint. The footprint specified in the schematic is loaded from the PCB library when you load the netlist. Double-click on a schematic component to specify the footprint.

When you are in any editing or placement mode (a cross hair cursor is active), moving the cursor to the edge of the document window will automatically pan the document.

If you accidentally pan too far while you are wiring up your circuit, press V, F (View » Fit All Objects) to redraw the schematic window, showing all placed objects. This can be done even when you are in the middle of placing an object.

is drawn as a mirror of Q1. To flip the orientation of the transistor that is floating on the cursor, press the X key. This flips the component horizontally.

- Move the cursor to position the part to the right of Q1. To position the component more accurately, press the **PAGEUP** key twice to zoom in two steps. You should now be able to see the grid lines.
- Once you have positioned the part, left-click or press ENTER to place
   Q2. Once again a copy of the transistor you are "holding" will be placed on the schematic, and the next transistor will be floating on the cursor ready to be placed.
- 6. Since we have now placed all the transistors, we will exit part placement mode by clicking the right mouse button or pressing the **ESC** key. The cursor will revert back to a standard arrow.

Next we will place the four resistors.

- 1. In the Libraries panel, make sure the Miscellaneous Devices.IntLib library is active.
- 2. Set the filter by typing res1 in the filter field below the Library name.
- 3. Click on **Res1** in the components list to select it, then click the **Place** button. You will now have a resistor symbol floating on the cursor.
- 4. Press the **TAB** key to edit the resistor's attributes. In the Properties section of the dialog, set the value for the first component designator by typing R1 in the Designator field.
- 5. Make sure that footprint name AXIAL-0.3 is included in the Models list.
- The contents of Comment field of the schematic component maps to the Comment field of the PCB component, typically you would enter the value or the resistor here. Enter a value of 100k into the Comment field for R1.

Components being simulated may have a number of simulation properties that can be defined (eg, a resistor has 1, a BJT has 5, and a MOSFET has 13), these properties are defined by using Parameters. If you wanted to simulate this circuit then the resistor value must be defined as a Parameter, whose name is Value and whose value is the resistance.

If the circuit being captured is for both simulation and PCB layout, rather than enter the value twice (in the parameter called Value and then in the Comment field), Altium Designer supports 'indirection', a feature that maps any parameter's string into the Comment field. If you click to display the Comment field dropdown list you will see that the software has automatically build a list of all current parameters, in case you want to map the value of one of them into the Comment field.

- 7. Since you will not be simulating ensure that the Visible check box for the Value parameter is clear.
- 8. Press the **SPACEBAR** to rotate the resistor by 90° so it is in the correct orientation.
- Position the resistor above the base of Q1 (refer to the schematic diagram in Figure 1) and left-click or press ENTER to place the part. Don't worry about making the resistor connect to the transistor just yet. We will wire up all the parts later.
- 10. Next place the other 100k resistor R2 above the base of Q2. The designator will automatically increment when you place the second resistor.
- 11. The remaining two resistors, R3 and R4, have a value of 1k, so press the **TAB** key to call up the *Component Properties* dialog, enter 1k into the **Comment**, and confirm that the **Visible** checkbox for the **Value** parameter is cleared. Click **OK** to close the dialog.

Use the following keys to manipulate the part floating on the cursor:

- Y flips the part vertically
- X flips the part horizontally
- Spacebar rotates the part by 90°.

#### To edit the attributes of an object placed on the schematic, double-click the object to open its *Component Properties* dialog.

12. Position and place R3 and R4 as shown in the schematic diagram in Figure 1. Right-click or press **ESC** to exit part placement mode.

Now place the two capacitors.

- 1. The capacitor part is also in the Miscellaneous Devices.IntLib library, which should already be selected in the **Libraries** panel.
- 2. Type cap in the component's filter field in the Libraries panel.
- 3. Click on **CAP** in the components list to select it, then click the **Place** button. You will now have a capacitor symbol floating on the cursor.
- 4. Press the **TAB** key to edit the capacitor's attributes. In the *Component* Properties dialog set the **Designator** to C1, the **Comment** to 20n, clear the **Visible** checkbox for the **Value** parameter, and check the PCB footprint model RAD-0.3 is selected in the **Models** list. Click **OK**.

As with the resistor, if you wanted to simulate this circuit you would need a Value parameter with the value of 20n, in this case you would define the capacitance in the Value parameter and then use the indirection feature to map the contents of the value parameter into the Comment field. Since you will not be simulating ensure that the **Visible** check box for the **Value** parameter is clear.

- 5. Position and place the two capacitors in the same way that you placed the previous parts.
- 6. Right-click or press **ESC** to exit placement mode.

The last component to be placed is the connector, located in Miscellaneous Connectors.IntLib.

- 1. Select Miscellaneous Connectors.IntLib from the Libraries list in the Libraries panel. The connector we want is a two-pin socket, so set the filter to \*2\*.
- Select Header 2 from the parts list and click the Place button. Press TAB to edit the attributes and set Designator to Y1 and check the PCB footprint model is HDR1X2. No Value parameter is required as you would replace this component with a power source when simulating the circuit. Click OK to close the dialog.
- 3. Before placing the connector, press **X** to flip it horizontally so that it is in the correct orientation. Click to place the connector on the schematic.
- 4. Right-click or press **ESC** to exit part placement mode.
- 5. Save your schematic by selecting File » Save from the menus [shortcut F, S].

You have now placed all the components. Note that the components in Figure 2 are spaced so that there is plenty of room to wire to each component pin. This is important because you can not place a wire across the bottom of a pin to get to a pin beyond it. If you do, both pins will connect to the wire.

If you need to move a component, click-and-hold on the body of the component, then drag the mouse to reposition it.

To reposition any object, simply place the cursor directly over the object, click-and-hold the left mouse button, drag the object to a new position and then release the mouse button.



Figure 2. Schematic with all parts placed.

### Wiring up the circuit

Wiring is the process of creating connectivity between the various components of your circuit. To wire up your schematic, refer to the diagram in Figure 1 and complete the following steps.

- To make sure you have a good view of the schematic sheet, use the PAGE UP key to zoom in or PAGE DOWN to zoom out. Also try holding down the **Ctrl** key and using the mouse wheel to zoom.
- Firstly wire the resistor R1 to the base of transistor Q1 in the following manner. Select Place » Wire [shortcut P, W] from the menus or click on the Wire tool from the Wiring toolbar to enter the wire placement mode. The cursor will change to a crosshair.
- 3. Position the cursor over the bottom end of R1. When you are in the right position, a red connection marker (large asterisk) will appear at the cursor location. This indicates that the cursor is over an electrical connection point on the component.
- 4. Left-click or press **ENTER** to anchor the first wire point. Move the cursor and you will see a wire extend from the cursor position back to the anchor point.
- Position the cursor so that it is below R1 and level with the base of Q1. Left-click or press ENTER to anchor the wire at this point. The wire between the first and second anchor points will be placed.
- Position the cursor over the base of Q1 until you see the cursor change to a red connection marker. Left-click or press ENTER to connect the wire to the base of Q1.
- Note that the cursor remains a cross hair, indicating that you are ready to place another wire. To exit placement mode completely and go back to the arrow cursor, you would right-click or press ESC again – but don't do this just now.

To graphically edit the shape of a wire, or any other graphical object once it has been placed, position the arrow cursor over it and click once.

Whenever a wire runs across the connection point of a component, or is terminated on another wire, Altium Designer will automatically create a junction.

When placing wires, keep in mind the following points:

- left-click or press ENTER to anchor the wire at the cursor position;
- press BACKSPACE to remove the last anchor point;
- after placing the last segment of a wire, right-click or press
   ESC to end the wire placement. The cursor will remain as a cross hair and you can begin placing another wire.
  - Right-click again or press **ESC** to exit wire placement mode.
- 8. We will now wire C1 to Q1 and R1. Position the cursor over the left connection point of C1 and left-click or press ENTER to start a new wire. Move the cursor horizontally till it is directly over the wire connecting the base of Q1 to R1. A connection marker will appear. Left-click or press ENTER to place the wire segment, then right-click or press ESC to indicate that you have finished placing the wire. Note how the two wires are automatically connected.
- 9. Wire up the rest of your circuit, as shown in Figure 3.



A wire that crosses the end of a pin will connect to that pin, even if you delete the junction. Check that your circuit looks like Figure 3 before proceeding.

Figure 3. The fully wired schematic

- 10. When you have finished placing all the wires, right-click or press **ESC** to exit placement mode. The cursor will revert to an arrow.
- 11. If you wish to move any placed components and drag any connected wires with it, hold down the **Ctrl** key while moving the component, or select **Move** » **Drag**.

#### Nets and net labels

Each set of component pins that you have connected to each other now form what is referred to as a *net*. For example, one net includes the base of Q1, one pin of R1 and one pin of C1.

To make it easy to identify important nets in the design, you can add *net labels*. To place net labels on the two power nets:

- 1. Select Place » Net Label [shortcut P, N]. A dotted box will appear floating on the cursor.
- 2. To edit the net label before it is placed, press the TAB key to display the Net Label dialog.
- 3. Type 12V in the **Net** field, then click **OK** to close the dialog.
- 4. Place the net label so that the bottom left of the net label touches the upper most wire on the schematic. The cursor will change to a red cross when the net label touches the wire. If the cross is light gray, it means you are trying to label a pin instead.



- 5. After placing the first net label you will still be in net label placement mode, so press the **TAB** key again to edit the second net label before placing it.
- 6. Type GND in the **Net** field, click **OK** to close the dialog and place the net label. Right-click or press ESC to exit net label placement mode.
- 7. Select File » Save [shortcut F, S] to save your circuit. Save the project as well.

Congratulations! You have just completed your first schematic capture using Altium Designer.

Before we turn the schematic into a circuit board, let's set up the project options.

# **Setting up Project Options**

The project options include the error checking parameters, a connectivity matrix, Class Generator, the Comparator setup, ECO generation, output paths and netlist options, Multi-Channel naming formats, Default Print setups, Search Paths and any project parameters you wish to specify. Altium Designer will use these setups when you compile the project.

When a project is compiled, comprehensive design and electrical rules are applied to verify the design. When all errors are resolved, the re-compiled schematic designs are loaded into the target document, e.g. a PCB document, by generated ECOs. The project Comparator allows you to find differences between source and target files and update (synchronize) in both directions.

All project-related operations, such as error checking, comparing documents and ECO generation, are set up in the *Options for Project* dialog (**Project** » **Project Options**).

Project outputs, such as assembly and fabrication outputs and reports can be set up from the File menu options. You can also set up job options in a Job Options file (**File** » **New** » **Output Job File**). See *Setting up the Project Outputs* for more information.

1. Select Project » Project Options. The Options for Project dialog displays:

| Error Reporting Connection Matrix Class Generation Comparator ECO Generation ( | Dptions Multi-Channel Default Prints Search Paths Parameter |
|--------------------------------------------------------------------------------|-------------------------------------------------------------|
| Violation Type Description                                                     | A Report Mode                                               |
| Violations Associated with Documents                                           |                                                             |
| Conflicting Constraints                                                        | 🚞 Error                                                     |
| Duplicate sheet numbers                                                        | 🧀 Warning                                                   |
| Duplicate Sheet Symbol Names                                                   | 🚞 Error                                                     |
| Missing child sheet for sheet symbol                                           | 🚞 Error                                                     |
| Missing Configuration Target                                                   | 🚞 Error                                                     |
| Missing sub-Project sheet for component                                        | 🧀 Warning                                                   |
| Multiple Configuration Targets                                                 | 🚞 Fatal Error                                               |
| Multiple Top-Level Documents                                                   | 🗀 Error                                                     |
| Port not linked to parent sheet symbol                                         | 🗀 Error                                                     |
| Sheet Entry not linked to child sheet                                          | 🗀 Error                                                     |
| Unique Identifiers Errors                                                      | 🗀 Warning                                                   |
| <ul> <li>Violations Associated with Nets</li> </ul>                            |                                                             |
| Adding hidden net to sheet                                                     | 🗀 Warning                                                   |
| Adding Items from hidden net to net                                            | 🗀 Warning                                                   |
| Auto-Assigned Ports To Device Pins                                             | 🗀 Warning                                                   |
| Duplicate Nets                                                                 | Error                                                       |
| Floating net labels                                                            | 🗀 Warning                                                   |
| Floating power objects                                                         | 🗀 Warning                                                   |
| Global Power-Object scope changes                                              | 🗀 Warning                                                   |
| Net Parameters with no name                                                    | 🗀 Warning                                                   |
| Net Parameters with no value                                                   | 🗀 Warning                                                   |
| Nets containing floating input pins                                            | Error                                                       |
| Nets containing multiple similar objects                                       | 🗀 Error                                                     |
| Nets with multiple names                                                       | 🗀 Warning 🗾 🔻                                               |
| Nets with no driving source                                                    | No Report                                                   |
| Nets with only one pin                                                         | Warning                                                     |
| Nets with possible connection problems                                         |                                                             |
| Object constants district const                                                | Fatal Error                                                 |

2. Set up any project-related options in this dialog. We will now make some changes to the Error Reporting, Connection Matrix and Comparator tabs.

### Checking the electrical properties of your schematic

Schematic diagrams in Altium Designer are more than just simple drawings – they contain electrical connectivity information about the circuit. You can use this connectivity awareness to verify your design. When you compile a project, Altium Designer checks for errors according to the rules set up in the **Error Reporting** and **Connection Matrix** tabs and any violations generated will display in the **Messages** panel.

### Setting up Error Reporting

The **Error Reporting** tab in the *Options for Project* dialog is used to set up design drafting checks. The Report Mode is the level of severity of a violation. If you wish to change a Report Mode, click on a Report Mode next to the violation you wish to change and choose the level of severity from the drop-down list. For this tutorial we will use the default settings.

### Setting up the Connection Matrix

The **Connection Matrix** tab (*Options for Project* dialog) displays the severity of an error type that is produced when error reporting is run to check electrical connections within the design, i.e. connections between pins, ports and sheet entries. The matrix gives a graphical representation of different types of connection points on a schematic and whether they are allowable or not.

For example, look down the entries on the right side of the matrix diagram and find **Output Pin**. Read across this row of the matrix till you get to the **Open Collector Pin** column. The square where they intersect is orange indicating that an Output Pin connected to an Open Collector Pin on your schematic will generate an error condition when the project is compiled.

You can set each error type with a separate error level, e.g. from no report at all through to a fatal error. Right-click to see the menu options to control the entire matrix.

To make changes to the Connection Matrix:

- 1. Click on the **Connection Matrix** tab in the *Options for Project* dialog.
- 2. Click on the box that is at the intersection of two types of connection, e.g. Output Sheet Entry and Open Collector Pin.
- Click until the box changes to the color of the errors as listed in the legend, e.g. an orange box indicates that an error will be generated if such a connection is found.

Our circuit contains only Passive Pins (on resistors, capacitors and the connector) and Input Pins (on the transistors. Let's check to see if the connection matrix will detect unconnected passive pins.

 Look down the row labels to find Passive Pin. Look across the column labels to find Unconnected. The square where these entries intersect indicates the error condition when a Passive Pin is found to be Unconnected in the



schematic. The default is a green square, which indicates that no report will be generated.

 Click on this intersection box until it turns yellow so that a warning will be generated for unconnected passive pins when we compile the project. We will purposely create an instance of this error to check it later in this tutorial.

### Setting up the Comparator

The **Comparator** tab in the *Options for Project* dialog sets which differences between files will be reported or ignored when a project is compiled. For this tutorial, we do not need to show differences between some features that refer to hierarchical schematic designs only, such as rooms. Make sure you do not accidentally ignore components when you meant to ignore component classes!

- 1. Click on the **Comparator** tab and find **Changed Room Definitions**, **Extra Room Definitions** and **Extra Component Classes** in the Difference Associated with Components section.
- Select Ignore Differences from the drop-down list in the Mode column to the right of the these options.

| Options for PCB | Project Multivi            | brator.PrjPCB    |               |                      |            |               |                  |                   | ? 🗙        |
|-----------------|----------------------------|------------------|---------------|----------------------|------------|---------------|------------------|-------------------|------------|
| Error Reporting | Connection Matrix          | Class Generation | Comparator    | ECO Generation       | Options    | Multi-Channel | Default Prints   | Search Paths      | Parameters |
| Comparison Type | Description                |                  |               |                      |            | ∆ Mo          | ode              |                   | ~          |
|                 | sociated with Comp         | onents           |               |                      |            |               |                  |                   |            |
|                 | hannel Class Name          |                  |               |                      |            |               | Find Differences |                   |            |
|                 | omponent Class Na          | me               |               |                      |            |               | Find Differences |                   |            |
|                 | et Class Name              |                  |               |                      |            |               | Find Differences |                   |            |
|                 | oom Definitions            |                  |               |                      |            |               | Find Differences |                   | <b>_</b>   |
| Changed R       | ule<br>asses With Extra Me |                  |               |                      |            |               | Ignore Differenc |                   |            |
|                 | Classes With Extra Me      |                  |               |                      |            |               | Find Differences | •                 |            |
| Different Co    |                            | Members          |               |                      |            |               | Find Differences |                   |            |
| Different De    |                            |                  |               |                      |            |               | Find Differences |                   |            |
| Different Fo    |                            |                  |               |                      |            |               | Find Differences |                   |            |
| Different Lib   | orary References           |                  |               |                      |            |               | Find Differences |                   |            |
| Different Ty    |                            |                  |               |                      |            |               | Find Differences |                   |            |
| Extra Chann     |                            |                  |               |                      |            |               | Find Differences |                   |            |
|                 | onent Classes              |                  |               |                      |            |               | Find Differences |                   |            |
| Extra Comp      |                            |                  |               |                      |            |               | Find Differences |                   |            |
| Extra Room      |                            |                  |               |                      |            |               | Find Differences |                   | ~          |
|                 | accusted with filete       |                  |               |                      |            |               |                  |                   |            |
|                 |                            |                  |               | Object Matching Crit |            |               |                  |                   |            |
| Object Type     | Min Match                  |                  | atched Member |                      | me Matchir | -             |                  | al Matching Dialo | g          |
| Net             | 75                         | 3                |               |                      | member m   |               |                  | tched objects     |            |
| Net Class       | 75                         | 3                |               |                      | member m   | -             | -                | tched objects     |            |
| Component Class | 75                         | 3                |               | 🍼 After              | member m   | natching      | 🌏 For unma       | tched objects     |            |
|                 |                            |                  |               |                      |            |               |                  |                   |            |
|                 |                            |                  |               |                      |            |               |                  |                   |            |
| Ignore Rules    | s Defined in PCB Or        | ıly              |               |                      |            |               |                  |                   |            |
| Set To Default  |                            |                  |               |                      |            |               |                  | ПК                | Cancel     |
|                 | <u> </u>                   |                  |               |                      |            |               |                  |                   | Cancer     |

Now we are ready to compile the project and check for any errors.

# **Compiling the project**

Compiling a project checks for drafting and electrical rules errors in the design documents and puts you into a debugging environment. We have already set up the rules in the Error Checking and Connection Matrix tabs of the *Options for Project* dialog.

- 1. To compile our Multivibrator project, select Project » Compile PCB Project.
- 2. When the project is compiled, any errors generated will display in the Messages panel. Click on this panel to check for errors (View » Workspace Panels » System » Messages). The compiled documents will be listed in the Navigator panel, together with a flattened hierarchy, components and nets listed and a connection model that can be browsed.

If your circuit is drawn correctly, the Messages panel should not contain any errors. If the report gives errors, check your circuit and ensure all wiring and connections are correct.

We will now deliberately introduce an error into our circuit and recompile the project:

- 1. Click on the Multivibrator.SchDoc tab at the top of the design window to make the schematic sheet the active document.
- 2. Click in the middle of the wire that connects R1 to the base wire of Q1. Small, square editing handles will appear at each end of the wire and the selection color will display as a dotted line along the wire to indicate that it is selected. Press the **DELETE** key to delete the wire.
- Recompile the project (Project » Compile PCB Project) to check that any errors are found. The Messages panel will display warning messages indicating you have unconnected pins in your circuit. Select View » Workspace Panels » System » Messages if the Messages panel is not displayed.
- 4. Double-click on an error or warning in the Messages panel and the *Compile Error* window will display with details of the violation. From this window, you can click on an error and jump to the violating object in a schematic to check or correct the error.

Before we finish this section of the tutorial, let's fix the error in our schematic.

- 1. Click on the tab of the schematic sheet to make it active.
- Select Edit » Undo from the menus [shortcut Ctrl+Z]. The wire you deleted previously should now be restored.
- To check that the undo was successful, recompile the project (Project » Compile PCB Project) to check that no errors are found. The Messages panel should show no errors.

If you wish to clear messages from the Messages panel, rightclick in the window and select **Clear All**.

- Select View » Fit All Objects [shortcut V, F] from the menus to restore your schematic view and save your error-free schematic.
- 5. Save the schematic and the project file as well.

Now we have completed and checked our schematic, it is time to create the PCB.

# **Creating a new PCB document**

Before you transfer the design from the Schematic Editor to the PCB Editor, you need to create the blank PCB with at least a board outline. The easiest way to create a new PCB design in Altium Designer is to use the PCB Wizard, which allows you to choose from industry-standard board outlines as well as create your own custom board sizes. At any stage you can use the **Back** button to check or modify previous pages in the wizard.

To create a new PCB using the PCB Wizard, complete the following steps:

- Create a new PCB by clicking on PCB Board Wizard in the New from Template section at the bottom of the Files panel. If this option is not displayed on the screen, close some of the sections above by clicking on the up arrow icons.
- 2. The PCB Board Wizard opens. The first screen you see is the introduction page. Click the **Next** button to continue.
- Set the measure units to Imperial, i.e. 1000 mils = one inch.
- The third page of the wizard allows you to select the board outline you wish to use. For this tutorial we will enter our own board size. Select Custom from the list of board outlines and click Next.
- In the next page you enter custom board options. For the tutorial circuit, a 2 x 2 inch board will give us plenty of room. Select **Rectangular** and type 2000 in both the Width and Height fields. Deselect **Title Block & Scale**,



Legend String and Dimension Lines. Click Next to continue.

- 6. This page allows you to select the number of layers in the board. We will need two signal layers and no power planes. Click **Next** to continue.
- 7. Choose the via styles used in the design by selecting Thruhole Vias only and click Next.
- The next page allows you to set the component/track technology (routing) options. Select the Through-hole components option and set the number of tracks between adjacent pads to One Track. Click Next.
- 9. The next page, *Default Track and Via Sizes*, allows you to set up some of the design rules that apply to your board. Leave the options on this screen set to their defaults. Click the **Next** button to continue.
- 10. Click **Finish** to close the Wizard. The PCB Wizard has now collected all the information it needs to create your new board. The PCB Editor will now display a new PCB file named PCB1.PcbDoc.



11. The PCB document displays with a default sized white sheet and a blank board shape (black area with grid). To turn it off, select **Design** » **Board Options** and deselect **Display Sheet** in the *Board Options* dialog.

For more tutorials, press **F1** to access the Altium Designer Documentation Library.

You can add your own border, grid reference and title block from other PCB templates supplied with Altium Designer.

- For more information about using board shapes, sheets and templates, refer to the *Preparing the Board for Design Transfer* tutorial.
  - 12. Now the sheet has been turned off, display the board shape only by selecting **View** » **Fit Board** [shortcut **V**, **F**].
  - 13. The PCB document is automatically added (linked) to the project and is listed under Source Documents beneath the project name in the **Projects** tab. Rename the new PCB file (with a .PcbDoc extension) by selecting **File** » **Save As**. Navigate to a location where you would like to store the PCB on your hard disk, type the name Multivibrator.PcbDoc in the File Name field and click on **Save**.

#### Adding a new PCB to a project

If the PCB you want to add to a project file has been opened as a Free Document, right-click on the PCB project file in the Projects panel and select **Add Existing to Project**. Choose the new PCB file

name and click on **Open**. The PCB is now listed under Source Documents beneath the project in the **Projects** panel and is linked to the project file. Save the project file.

## Transferring the design

Before transferring the schematic information to the new blank PCB, make sure all the related libraries for both schematic and PCB are available. Since only the default installed integrated libraries are used in this tutorial, the footprints will already be included. Once the project has been compiled and any errors in the schematic fixed, use the **Update PCB** command to generate ECOs that will transfer the schematic information to the target PCB.

### **Updating the PCB**

To send the schematic information to the target PCB in your project:

- 1. Open the schematic document, Multivibrator.SchDoc.
- 2. Select **Design** » **Update PCB Document** (Multivibrator.PcbDoc). The project compiles and the *Engineering Change Order* dialog displays.

| Er | gineering      | g Change Order    |                             |        |                   |        |      | ? 🗙     |
|----|----------------|-------------------|-----------------------------|--------|-------------------|--------|------|---------|
| Mo | odifications   |                   |                             |        |                   | Status |      |         |
|    | Enable $ able$ | Action            | Affected Object             |        | Affected Document | Check  | Done | Message |
| Ξ  |                | Add Components(9) |                             |        |                   |        |      |         |
|    | ✓              | Add               | 📕 C1                        | To     | H H               |        |      |         |
|    | ✓              | Add               | 📕 C2                        | То     | 開始                |        |      |         |
|    | ✓              | Add               | 🌗 Q1                        | То     |                   |        |      |         |
|    | ✓              | Add               | 🕕 Q2                        | То     |                   |        |      |         |
|    | ✓              | Add               | 🕕 R1                        | То     | 調整                |        |      |         |
|    | ✓              | Add               | 📙 R2                        | То     | HEP               |        |      |         |
|    | ✓              | Add               | 🕕 R3                        | То     |                   |        |      |         |
|    | ✓              | Add               | 📕 R4                        | То     |                   |        |      |         |
|    | ✓              | Add               | 🕕 Y1                        | То     | HB)               |        |      |         |
| Ξ  |                | Add Nets(6)       |                             |        |                   |        |      |         |
|    | ✓              | Add               | 🔁 12V                       | То     |                   |        |      |         |
|    | ✓              | Add               | 🔁 GND                       | То     | 開設                |        |      |         |
|    | ✓              | Add               | ≈ NetC1_1                   | То     | H H               |        |      |         |
|    | ✓              | Add               | 🔁 NetC1_2                   | To     | HP.               |        |      |         |
|    | ✓              | Add               | ≈ NetC2_1                   | To     | H H               |        |      |         |
|    | ✓              | Add               | 🔁 NetC2_2                   | То     | 開始                |        |      |         |
|    |                |                   |                             |        |                   |        |      |         |
|    | /alidate Cha   | nges Execute Cha  | nges <u>R</u> eport Changes | 🗌 Only | Show Errors       |        |      | Close   |

- Click on Validate Changes. If all changes are validated, the green ticks appear in the Status list. If the changes are not validated, close the dialog, check the Messages panel and clear any errors.
- 4. Click on **Execute Changes** to send the changes to the PCB. When completed, the Status changes to Done.

You can create a report of ECOs to print out by clicking on the **Report Changes** button.

 Click Close and the target PCB opens with components positioned ready for placing on the board. Use the shortcut keys V, D (View Document) if you cannot see the components in your current view.



Figure 4. The components next to the board, ready for positioning.

# **Designing the PCB**

Now we can start placing the components on the PCB and routing the board.

### Setting up the PCB workspace

Before we start positioning the components on the board, we need to set up the PCB workspace, such as the grids, layers and design rules.

#### Grids

We need to ensure that our placement grid is set correctly before we start positioning the components. All the objects placed in the PCB workspace are aligned on a grid called the *snap grid*. This grid needs to be set to suit the routing technology that you intend to use.

Our tutorial circuit uses standard imperial components that have a minimum pin pitch of 100mil. We will set the snap grid to an even fraction of this, say 50 or 25mil, so that all

component pins will fall on a grid point when placed. Also, the track width and clearance for our board are 12mil and 13mil respectively (the default values used by the PCB Board Wizard), allowing a minimum of 25mil between parallel track centers. The most suitable snap grid setting would, therefore, be 25mil.



To set the snap grid, complete the following steps:

- 1. Select **Design** » **Board Options** [shortcut **D**, **O**] to open the *Board Options* dialog.
- Set the values of the Snap Grid and the Component Grid to 25mil using the drop-down lists or typing in the value. Note that this dialog is also used to define the Electrical Grid. The Electrical Grid operates when you place an electrical object; it overrides the snap grid and snaps electrical objects together. Click OK to close the dialog.

Let's set some other options that will make positioning components easier.

 Select Tools » Preferences [shortcut T, P] to open the Preferences dialog. Click on PCB Editor – General in the dialog's selection tree (left side panel) to display the PCB Editor – General page. In the Editing Options section, make sure the Snap to Center option is checked. This ensures that when you "grab" a component to position it, the cursor is set to the component's reference point.

| + 📴 System<br>€ 🛅 Schematic<br>+ 🛅 FPGA                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             | PCB Editor – Ge | neral                                                                                                                                                                                                                           |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-----------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| <ul> <li>Wersion Control</li> <li>Wersion Control</li> <li>Embedded System</li> <li>PCB Editor</li> <li>PCF Editor</li> <li>PCB 20</li> <li>PCB 20</li> <li>Text Editors</li> <li>PCA Editor</li> <li>PCB AD</li> <li>PCB</li></ul> | Editing Options | Autopan Options Style Adaptive Speed 1200 Pixels/Sec Mils/Sec Polygon Repour Repour Repour Threshold 5000 Elle Format Change Repot Disable opening the report from older versions Disable opening the repot from newer versions |

 Click on PCB Editor – Board Insight Display in the *Preferences* dialog's selection tree to make it the active page. In the Pad and Via Display Options section of this page, uncheck the Pad Nets, Pad Numbers and Via Nets options. Lastly, click on PCB Editor – Display. In the Draft Thresholds section of this page, check the Strings field is 4 pixels and click OK to close the Display of the Pad Nets.

| Preferences dialog.                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                  |             |                                                    |                |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------|-------------|----------------------------------------------------|----------------|
| Preferences                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                             |                  |             |                                                    | ? 🛛            |
| System     System     Schematic     Fr6A     Wersion Control     Embedded System     PCB Editor     General     Display     Board Insight Modes     Board Insight Modes     Board Insight Hodes     Board Insight Modes     Board Insight Modes | PCB Edit         | tor – Board | Net Names of<br>Display<br>Single Layer<br>Current |                |
| Set To Defaults 🔻 Save                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                  | Load Import From | •           | 0                                                  | K Cancel Apply |

### Defining the layer stack and other non-electrical layers

If you look at the bottom of the PCB workspace, you will notice a series of layer tabs. The PCB Editor is a multi-layered environment and most of the editing actions you perform will be on a particular layer. Select **Design** » **Board Layers & Colors** [shortcut **L**] to display the *Board Layers & Colors* dialog where you can display, add, remove and rename and set the colors of the layers.

| loard Layers and                               | Colors        |                 |                     |             |      |                         |          |          |           |                         | ?                  |
|------------------------------------------------|---------------|-----------------|---------------------|-------------|------|-------------------------|----------|----------|-----------|-------------------------|--------------------|
| Signal Layers (S)<br>Top Layer<br>Bottom Layer | Color         | Show            | Internal Planes (P) | Color       | Show | Mechanical<br>Layers(M) | Color    | Show     |           | Single<br>Layer<br>Mode | Linked To<br>Sheet |
| Bottom Layer                                   |               |                 |                     |             |      | Mechanical 1            |          | ~        | ~         |                         |                    |
| 🗹 Only show layers                             | in layer sta  | ack             | Only show planes    | in layer sl | tack | Only show enab          | led mech | anical L | ayers     | Lay                     | er Pairs           |
| Mask Layers (A)                                | Color         | Show            | Other Layers (O)    | Color       | Show | System Colors (Y)       |          |          |           | Color                   | Show               |
| Top Paste                                      |               |                 | Drill Guide         |             |      | Connections and E       | rom Tos  |          |           |                         | ~                  |
| Bottom Paste                                   |               |                 | Keep-Out Laver      |             | ~    | DBC Error Markets       |          |          |           |                         | ~                  |
| Top Solder                                     |               |                 | Drill Drawing       |             | П    | Selections              |          |          |           | 1                       |                    |
| Bottom Solder                                  |               |                 | Multi-Laver         |             | ~    | Visible Grid 1          |          |          |           |                         |                    |
|                                                |               | Land            |                     | _           |      | Visible Grid 2          |          |          |           |                         | ~                  |
|                                                |               |                 |                     |             |      | Pad Holes               |          |          |           |                         | ~                  |
|                                                | a provide     |                 |                     |             |      | Via Holes               |          |          |           |                         | <b>&gt;</b>        |
| Silkscreen Layers (K                           | () Color      | Show            |                     |             |      | Highlight Color         |          |          |           |                         |                    |
| Top Overlay                                    |               | ~               |                     |             |      | Board Line Color        |          |          |           |                         |                    |
| Bottom Overlay                                 |               |                 |                     |             |      | Board Area Color        |          |          |           |                         |                    |
|                                                |               |                 |                     |             |      | Sheet Line Color        |          |          |           |                         |                    |
|                                                |               |                 |                     |             |      | Sheet Area Color        |          |          |           |                         |                    |
|                                                |               |                 |                     |             |      | Workspace Start C       | olor     |          |           |                         | 1                  |
|                                                |               |                 |                     |             |      | Workspace End C         | olor     |          |           |                         |                    |
| All On All                                     | <u>o</u> ff [ | <u>U</u> sed On | Selected On Sel     | ected Off   | Cļea | r Default Co            | lor Set  | Classic  | Color Set | ]                       |                    |
|                                                |               |                 |                     |             |      |                         |          |          |           |                         | Cancel             |

There are three types of layers in the PCB Editor:

- Electrical layers these include the 32 signal layers and 16 plane layers. Electrical layers are added to and removed from the design in the Layer Stack Manager, select **Design** » Layer Stack Manager to display this dialog.
- **Mechanical layers** there are 16 general purpose mechanical layers for defining the board outline, placing dimensions on, including fabrication details on, or any other mechanical details the design requires. These layers can be selectively included in print and Gerber output generation. You can add, remove and name mechanical layers in the *Board Layers & Colors* dialog.
- **Special layers** these include the top and bottom silkscreen layers, the solder and paste mask layers, drill layers, the Keep-Out layer (used to define the electrical boundaries), the multilayer (used for multilayer pads and vias), the connection layer, DRC error layer, grid layers and hole layers. The display of these special layers is controlled in the *Board Layers & Colors* dialog.

#### Layer Stack Manager

The tutorial is a simple design and can be routed as a single-sided or double-sided board. If the design was more complex, you would add more layers in the Layer Stack Manager.

1. Select Design » Layer Stack Manager [shortcut D, K] to display the Layer Stack Manager dialog.

| Layer Stack Manager                         | ? 🛛         |
|---------------------------------------------|-------------|
| Top Layer → Core (12.6mi)<br>Bottom Layer → | Layer Pairs |
| 賢 Menu                                      | OK Cancel   |

2. New layers and planes are added below the currently selected layer. Layer properties, such as copper thickness and dielectric properties are used for signal integrity analysis. Click **OK** to close the dialog.

The new board has opened with many more layers enabled than you will use, so let's turn off all the unnecessary layers. To turn off layers, complete the following steps:

- 1. Press the L shortcut key to display the Board Layers & Colors dialog.
- 2. Click on Used On to disable all layers except those that have something on them.
- 3. Make sure the four **Mask** layers and the **Drill Drawing** layer will not display by checking there is no tick in the **Show** button next to their layer names. Click **OK** to close the dialog.

### Setting up new design rules

The PCB Editor is a rules-driven environment. This means that as you work in the PCB Editor and perform actions that change the design, such as placing tracks, moving components, or autorouting the board, the PCB Editor constantly monitors each action and checks to see if the design still complies with the design rules. If it does not, then the error is immediately highlighted as a violation. Setting up the design rules before you start working on the board allows you to remain focused on the task of designing, confident in the knowledge that any design errors will immediately be flagged for your attention.

The design rules fall into ten categories and are further divided into design rule types. The design rules cover electrical, routing, manufacturing, placement and signal integrity requirements.

We will now set up new design rules to specify the width that the power nets must be routed.

To set up these rules, complete the following steps:

- 1. With the PCB as the active document, select **Design** » **Rules** from the menus.
- 2. The *PCB Rules and Constraints Editor* dialog will appear. Each category of rules is displayed in the Design Rules panel (left hand side) of the dialog. Double-click on the **Routing** category to expand the category and see the related routing rules. Then double-click on **Width** to display the width rules available.

| 🐱 Design Rules       | Name               | P 🛆 🛛 | En | Туре                  | Category      | Sco | pe    | Attributes             |
|----------------------|--------------------|-------|----|-----------------------|---------------|-----|-------|------------------------|
| 🗄 🌄 Electrical       | S RoutingLayers    | 1     | ~  | Routing Layers        | Routing       | All |       | TopLayer - Horizont    |
| 吏 🚟 Routing          | and RoutingCorners | 1     | ~  | Routing Corners       | Routing       | All |       | Style - 45 Degree      |
| 😟 🖦 SMT              | 🖧 RoutingVias      | 1     | ✓  | Routing Via Style     | Routing       | All |       | Pref Size = 62mil F    |
| 🛨 📟 Mask             | PlaneConnect       | 1     | ✓  | Power Plane Connect S | Plane         | All |       | Style - Relief Connec  |
| 🗄 🔠 Plane            | 💎 HoleSize         | 1     | ✓  | Hole Size             | Manufacturing | All |       | Min = 1 mil Max = 1    |
| 🗄 💇 Testpoint        | 🚟 Width            | 1     | -  | Width                 | Routing       | All |       | Pref Width = 12mil     |
| 吏 ᅏ Manufacturing    | Tlearance          | 1     | -  | Clearance             | Electrical    | All | - All | Clearance = 13mil      |
| 🕀 🚟 High Speed       | PolygonConnect     | 1     | ~  | Polygon Connect Style | Plane         | All |       | Style - Relief Connec  |
| 🗉 🕕 Placement        | 🚟 RoutingPriority  | 1     | ~  | Routing Priority      | Routing       | All |       | Priority = 0           |
| 🖭 🎼 Signal Integrity | PasteMaskExpar     | 1     | ✓  | Paste Mask Expansion  | Mask          | All |       | Expansion = Omil       |
|                      | SolderMaskExpa     | 1     | ~  | Solder Mask Expansion | Mask          | All |       | Expansion = 4mil       |
|                      | 🖧 RoutingTopology  | 1     | ~  | Routing Topology      | Routing       | All |       | Topology - Shortest    |
|                      | 🥍 TestPointUsage   | 1     | ✓  | Testpoint Usage       | Testpoint     | All |       | Testpoint - Required   |
|                      | 🥍 Testpoint        | 1     | ✓  | Testpoint Style       | Testpoint     | All |       | Under Comp - Allow     |
|                      | ShortCircuit       | 1     | ✓  | Short-Circuit         | Electrical    | All | - All | Short Circuit - Not Al |
|                      | <                  |       | -  |                       |               |     |       |                        |

- 3. Click once on each rule in the Design Rules panel to select it. As you click on each rule, the right hand side of the dialog displays the rule's scope (what you want this rule to target) in the top section and the rule's constraints in the bottom section. These rules are either defaults, or have been set up by the Board Wizard when the new PCB document was created.
- Click on the Width rule to display its scope and constraints. This rule applies to the entire board (scope = All).

| Image: Soluting Topology         Image: Topology         Image: Topology </th <th>PCB Rules and Constraints Editor</th> <th>Name Width Comment Unique ID NRKYBBMC</th> | PCB Rules and Constraints Editor                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                          | Name Width Comment Unique ID NRKYBBMC                                                                                                                                                                                                      |
|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|---------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|--------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Attributes on Layer         Layer Stack Reference         Absolute Layer           Min Width         Preferred Size         Max Width         Name         Index           12mil         12mil         12mil         Top Layer         0         Top Layer         1                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                   | South *     South and the second | All     Net     Net     Layer     Query Helper     All     All     Net     Advanced (Query)     Query Builder      Constraints     Preferred Width 12mil     Min Width 12mil     Max Width 12mil     Characteristic Impedance Driven Width |
|                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                           | Min Width         Preferred Size         Max Width         Name         Index         Name         Index           12mil         12mil         12mil         12mil         12mil         Top Layer         0         TopLayer         1    |

One of the powerful features of Altium Designer's design rule system is that multiple rules of the same type can be defined, each targeting different objects. The exact set of objects that each rule targets is defined by that rule's *scope*. The rule system uses a pre-defined hierarchy to work out which rule to apply to each object.

For example, you could have a width constraint rule for the whole board (meaning all tracks must be this width), a second width constraint rule for the ground net (this rule overrides the previous rule), and a third width constraint rule for a particular connection on the ground net (which overrides both of the previous rules). Rules are displayed in their order of priority.

Currently there is one width constraint rule for your design, which applies to the whole board (width = 12 mil). We will now add a new width constraint rule for the 12V and GND nets (width = 25 mil). To add new width constraint rules, complete the following steps:

1. With the **Width** category selected in the **Design Rules** panel, right-click and select **New Rule** to add a new width constraint rule set up to target the 12V net only.

A new rule named Width\_1 appears. Click on the new rule in the **Design Rules** panel to modify the scope and constraints.

- 2. Type 12V or GND in the Name field. The name will refresh in the **Design Rules** panel when you click back in the Design Rules panel when you have finished setting the rule.
- 3. Next we set the rule's scope using the Query Builder but you can always type in the scope directly if you know the correct syntax. If your query is more complicated, click on the **Advanced** button and use the Query Helper.
- 4. Click on the Query Builder button to open the Building Query from Board dialog.

| Building Query from Bo    | ard                | ? 🛛           |
|---------------------------|--------------------|---------------|
| Show All Levels 🛛 👻       | • • • • • -        | ×             |
| Condition Type / Operator | Condition Value    | Query Preview |
| Belongs to Net            | 12V                | InNet('12∨')  |
| OR                        |                    | OR            |
| Belongs to Net            | GND                | InNet('GND')  |
| Add another condition     | NetC2_2            |               |
|                           | NetC2_1<br>NetC1_2 |               |
|                           | NetC1_1            |               |
|                           | GND                | K Cancel      |
|                           | 12V h              |               |

- Click on Add first condition and select Belongs to Net from the drop-down list. In the Condition Value field, click and select the net 12V from the list. The Query Preview now reads InNet (`12V').
- 6. Click on Add another condition to widen the scope to include the GND net. Select Belongs to Net and GND as the Condition Value.
- 7. Change the operator by clicking on the operator 'AND' and then select **OR** from the drop-down list. Check that the query preview reads InNet('12V') OR InNet('GND').
- 8. Click **OK** to close the *Building Query from Board* dialog. The scope in the **Full Query** section has now been updated with the new query.
- 9. In the bottom section of the *PCB Rules and Constraints Editor* dialog, change the **Minimum**, **Preferred** and **Maximum** width fields to 25mil by clicking on the old constraints text (10mil) and typing in the new values. Note that you must set the Maximum width field first before you can change the Minimum value. The new rule is now set up and will save when you choose another rule in the Design Rules panel or close the dialog.

| PCB Rules and Constraints Editor                                                                                                                                  | ? 🛛                                                                                                                                                                                                                                                                                                                                                  |
|-------------------------------------------------------------------------------------------------------------------------------------------------------------------|------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|
| Design Rules     Electrical     Clearance     Sont-Circuit     Un-Routed Net     Un-Connected Pin     Routing     Width     Souting Topology     Souting Topology | Name       12V or GND       Comment       Unique ID         Where the First object matches       (InNet ('12V') OR         All       (InNet ('12V') OR         Net Class       (InNet ('GND'))         Net and Layer       Query Helper         Advanced (Query)       Query Builder                                                                 |
|                                                                                                                                                                   | Preffered Width 25mil<br>Min Width 25mil<br>Max Width 25mil<br>Characteristic Impedance Driven Width<br>Layers in layerstack only                                                                                                                                                                                                                    |
| Manufacturing     High Speed                                                                                                                                      | Attributes on Layer Layer Stack Reference Absolute Layer                                                                                                                                                                                                                                                                                             |
| <ul> <li>IPlacement</li> <li>Im-Signal Integrity</li> </ul>                                                                                                       | Min Width         Preferred S         Max Width         Name         In         Name         In         A           25mil         25mil         25mil         25mil         25mil         Top Layer         0         Top Layer         1           25mil         25mil         25mil         Bottom Layer         1         Bottom Layer         32 |
| Priorities <u>R</u> ule Wizard                                                                                                                                    | Close                                                                                                                                                                                                                                                                                                                                                |

10. Finally, click to edit the original Board scope width rule named Width and confirm that the Minimum, Maximum and Preferred width fields are all set to 12mil. Click **Close** to close the *PCB Rules and Constraints Editor* dialog.

When you route the board manually or using the autorouter, all tracks will be 12mils wide, except the GND and 12V tracks which will be 25mils.

### Positioning the components on the PCB

Now we can start to place the components in their right positions.

- 1. Press the V, D shortcut keys to zoom in on the board and components.
- To place the connector Y1, position the cursor over the middle of the outline of the connector, and click-and-hold the left mouse button. The cursor will change to a cross hair and jump to the reference point for the part. While continuing to hold down the mouse button, move the mouse to drag the component.
- 3. Position the footprint towards the left-hand side of the board (ensuring that the whole of the component stays within the board boundary), as shown in Figure 5.



The connection lines are automatically re-optimized as you move a component. In this way you can use the connection lines as a guide to the optimum position and orientation of the component as you place it.

Figure 5. Components placed on the PCB

- 4. When the component is in position, release the mouse button to drop it into place. Note how the connection lines drag with the component.
- 5. Reposition the remaining components, using Figure 5 as a guide. Use the **SPACEBAR** key as necessary to rotate components as you drag them, so that the connection lines are as shown in Figure 5. Don't forget to re-optimize the connection lines as you position each component.

Component text can be repositioned in a similar fashion – click-and-hold to drag the text and press the **SPACEBAR** to rotate it.

Altium Designer also includes powerful interactive placement tools. Let's use these to ensure that the four resistors are correctly aligned and spaced.

1. Holding the **SHIFT** key, left-click on each of the four resistors to select them, or click and drag the selection box around them. A shaded selection box will display around each of the selected

components in the color set for the system color called Selections. To change this selection color, select **Design » Board Layers & Colors** [shortcut L].

- Right-click and select Align » Align [shortcut A, A]. In the Align Objects dialog, click on Space Equally in the Horizontal section and click on Top in the Vertical section. The four resistors are now aligned and equally spaced.
- 3. Click elsewhere in the design window to deselect all the resistors.



### **Changing a footprint**

Now that we have positioned the footprints, the capacitor footprint appears too big for our requirements! Let's change the capacitor footprint to a smaller one.

- 1. First we will browse for a new footprint. Click on the Libraries panel and select Miscellaneous Devices.IntLib from the Libraries list. We want a smaller radial type footprint, so type rad in the Filter field. Click on the ... button next to the library name and select Footprints to display footprints available in the active library. Click on the Footprint names to see the footprints associated with them. The footprint RAD-0.1 will do the job.
- 2. Double-click on the capacitors and change the Footprint field to RAD-0.1 in the *Component* dialog. You can simply type in the new footprint name, or click on the ... button and select a footprint from the *Browse Libraries* dialog. Click **OK** and the new footprints are displayed on the board. Reposition the designators as required.



3. Your board should now look like the PCB design in Figure 6 below.

*Figure 6. Components placed on the PCB with new footprints.* With everything positioned, it's time to do some routing!

### Manually routing the board

Routing is the process of laying tracks and vias on the board to connect the components. Altium Designer makes the job of routing easy by providing a number of sophisticated manual routing tools as well as the new powerful Situs topological auto./r, which optimally routes the whole or part of a board at the touch of a button.

While autorouting provides an easy and powerful way to route a board, there will be situations where you will need exact control over the placement of tracks – or you may want to route the board manually just for the fun of it! In these situations you can manually route part or all of your board. In this section of the tutorial, we will manually route the entire board "single-sided", with all tracks on the bottom layer.

We will now place tracks on the bottom layer of the board, using the "ratsnest" connection lines to guide us.

Tracks on a PCB are made from a series of straight segments. Each time there is a change of direction, a new track segment begins. Also, by default Altium Designer constrains tracks to a vertical, horizontal or 45° orientation, allowing you to easily produce professional results. This behavior can be customized to suit your needs, but for this tutorial we will stay with the default.

- Enable and show the Bottom Layer by pressing the shortcut key L to display the *Board Layers & Colors* dialog. Click on the **Show** checkbox next to Bottom Layer in the Signal Layers section. Click **OK** and the Bottom Layer tab is displayed in the design window.
- Select Place » Interactive Routing from the menus [shortcut P, T] or click the Interactive Routing button. The cursor will change to a cross hair indicating you are in track placement mode.
- Examine the layer tabs that run along the bottom of the document workspace. The **Top Layer** tab should currently be active. To switch to the bottom layer without dropping out of track placement mode, press the \* key on the numeric keypad. This key toggles bottwoon the available signal layers. The **Bottom Layer**



between the available signal layers. The **Bottom Layer** tab should now be active.

4. Position the cursor over the bottom-most pad on the connector Y1. Left-click or press **ENTER** to anchor the first point of the track.

5. Move the cursor towards the bottom pad of the resistor R1. Note how the track is laid. By default. tracks are constrained to vertical, horizontal or 45° directions. Also note that the track has two segments. The first (coming from the starting pad) is solid blue. This is the track segment you are actually placing. The second segment (attached to the cursor) is called the "look-ahead" segment and is drawn in outline. This segment allows you to look ahead at where the next track segment you lay could be positioned so that you can easily work your way around obstacles, maintaining a 45°/90° track orientation.

6. Position the cursor over the middle of the bottom pad of resistor R1 and left-click, or press the **ENTER** key. Note that the first track segment turns blue, indicating that it has been placed on the

Bottom Layer. Move the cursor around a little and you will see that you still have two segments attached to the cursor: a solid blue segment that will be placed with the next mouse click and an outlined "look-ahead" segment to help you position the track.

7. Re-position the cursor over the bottom pad of R1. You will have a solid blue segment extending from the previous segment to the pad. Left-click to place the solid blue segment.

You have just routed the first connection.

- 8. Move the cursor to position it over the bottom pad of resistor R4. Note a solid Preferences dialog. blue segment extends to R4. Left-click to place this segment.
- 9. Now move the cursor to the bottom pad of resistor R3. Note that this segment is not solid blue, but drawn in outline indicating it is a look-ahead segment. This is because each time you place a track segment the mode toggles between starting in a horizontal/vertical direction and starting at 45°. Currently it is in the 45° mode. Press the **SPACEBAR** key to togale the seament start mode to horizontal/vertical. The segment will now be drawn in solid blue. Left-click or press the ENTER key to place the segment.
- 10. Move the cursor to the bottom of resistor R2. Once again you will need to press the **SPACEBAR** key to toggle the segment start mode. Left-click or press the ENTER key to place the segment.
- 11. You have now finished routing the first net. Right-click or press the **ESC** key to indicate that you have finished placing this track. The cursor will remain a cross hair, indicating that you are still in track placement mode, ready to place the next track. Press the END key to redraw the screen so that you can clearly see the routed net.
- 12. You can now route the rest of the board in a similar manner to that described in the previous steps. Figure 7 shows the manually routed board.



Note that the look-ahead segment is clipping (no longer attached to the cursor). The PCB Editor will prevent you from accidentally placing a track across another object that would cause a violation. This connection must be routed around the capacitor.

You may find using a larger crosshair cursor useful when placing tracks. To change the cursor size. select **Tools** » Preferences. Select Large 90 from the Cursor Type list in the General page of the



Figure 7. Manually routed board, with tracks placed on the bottom layer. 13. Save the design [shortcut **F**, **S** or **Ctrl+S**].

### **Tips for placing tracks**

Keep in mind the following points as you are placing the tracks:

- Left-clicking the mouse (or pressing the **ENTER** key) places the track segment drawn in solid color. The outlined segment represents the look-ahead portion of the track. Placed track segments are shown in the layer color.
- Press the SPACEBAR key to toggle between the start horizontal/vertical and start 45° modes for the track segment you are placing.
- Press the END key at any time to redraw the screen.
- Press the V, F shortcut keys at any time to redraw the screen to fit all objects.
- Press the **PAGEUP** and **PAGEDOWN** keys at any time to zoom in or out, centered on the cursor position. Use the mouse wheel to pan left and right. Hold the **Ctrl** key down to zoom in and out with the mouse wheel.
- Press the BACKSPACE key to "unplace" the last track segment.
- Right-click or press ESC when you have finished placing a track and want to start a new one.
- You cannot accidentally connect pads that should not be wired together. Altium Designer continually analyzes the board connectivity and prevents you from making connection mistakes or crossing tracks.
- To delete a track segment, left-click on it to select it. The segment's editing handles will appear (the rest of the track will be highlighted). Press the **DELETE** key to clear the selected track segment.
- Re-routing is easy simply route the new track segments, when you right-click to finish the old redundant track segments will automatically be removed.
- When you have finished placing all the tracks on your PCB, right-click or press the **ESC** key to exit placement mode. The cursor will change back to an arrow.

Congratulations! You have manually routed your board design.

### Automatically routing the board

To see how easy it is to autoroute with Altium Designer, complete the following steps:

- 1. First, un-route the board by selecting Tools » Un-Route » All from the menus [shortcut U, A].
- 2. Select **Auto Route** » **All**. The *Situs Routing Strategies* dialog displays. Click on **Route All**. The Messages panel displays the process of the autorouting.

It's as simple as that! The Situs autorouter provides results comparable with that of an experienced board designer and because it routes your board directly in the PCB window, there is no need to wrestle with exporting and importing route files.

3. Select File » Save [shortcut F, S] to save your board.

Note that the tracks placed by the autorouter appear in two colors: red indicates that the track is on the top signal layer of the board and blue indicates the bottom signal layer. The layers that are used by the autorouter are specified in the **Routing Layers** design rule, which was set up by the PCB Board Wizard. You will also notice that the two power net tracks running from the connector are wider, as specified by the two new Width design rules you set up.

Don't worry if the routing in your design is not exactly the same as Figure 8. The component placement will not be exactly the same, so neither will be the routing.



Figure 8. Fully autorouted board

Because we originally defined our board as being double-sided in the PCB Board Wizard, you could manually route your board "double-sided" using both the top and bottom layers. To do this, un-route the board by selecting **Tools » Un-Route » All** from the menus [shortcut **U**, **A**]. Start interactive routing as before, but use the \* key to toggle between the layers while placing tracks. Altium Designer will automatically insert vias if necessary when you change layers.

### Verifying your board design

Altium Designer provides a rules-driven environment in which to design PCBs and allows you to define many types of design rules to ensure the integrity of your board. Typically, you set up the design rules

at the start of the design process and then verify that the design complies with the rules at the end of the design process.

Earlier in the tutorial we examined the routing design rules and added a new width constraint rule. We also noted that there were already a number of rules that had been created by the PCB Board Wizard.

To verify that the routed circuit board conforms to the design rules, we will now run a Design Rule Check (DRC):

1. Choose **Design** » **Board Layers & Colors** [shortcut **L**] and ensure that **Show** button next to the **DRC Error Markers** option in the System Colors section is checked (ticked) so that the DRC error markers will be displayed, if any.

Altium Designer supports hierarchical design rules. You can set any number of rules of the same class, each with a defined scope. The rule's priority determines the rule's precedence.

 Choose Tools » Design Rule Check from the menus [shortcut T, D]. Both the on-line and batch DRC options are configured in the *Design Rule Checker* dialog. Click on a category, e.g. Electrical, to see all the rules belonging to that category.

| Design Rule Checker                                                                                                                                                  |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | ? 🗙   |
|----------------------------------------------------------------------------------------------------------------------------------------------------------------------|----------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------|
| Report Options     Rules To Check     Section     Source     Section     Source     Section     Manufacturing     High Speed     Placement     More Signal Integrity | DRC Report Options         Image: Create Report File         Create Report File         Create Violations         Sub-Net Details         Internal Plane Warnings         Verify Shorting Copper         Stop when 500       violations found         To speed the process of rule checking enable only the rules that are required for the task being performed. Note: Options are only enabled when corresponding rules have been defined.         On-line DRC tests for design rule violations as you work. Include a Design Rule in the Design-Rules dialog to be able to test for a particular rule type. |       |
| <u>R</u> un Design Rule Check                                                                                                                                        |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Close |

- 3. Leave all options at their defaults and click the **Run Design Rule Check** button. The DRC will run and the report file Multivibrator.DRC opens. The results will also be displayed in the Messages panel. Click back into the PCB document and you will see that the transistor pads are highlighted in green, indicating a design rule violation.
- 4. Look through the errors list in the Messages panel. It lists any violations that occur in the PCB design. Notice that there are four violations listed under the Clearance Constraint rule. The details show that the pads of transistors Q1 and Q2 violate the 13mil clearance rule.
- 5. Double-click on an error in the Messages panel to jump to its location on the PCB.

Normally you would set up the clearance constraint rules before laying out your board, taking account of routing technologies and the physical properties of the devices. Let's analyze the error then review the current clearance design rules and decide how to resolve this situation.

To find out the actual clearance between the transistor pads:

- 1. With the PCB document active, position the cursor over the middle of one of the transistors and press the **PAGE UP** key to zoom in.
- 2. Select Reports » Measure Primitives [shortcut R, P]. The cursor will change to a cross hair.
- 3. Position the cursor over the middle of the left pad on the transistor and left-click or press ENTER. Because the cursor is over both the pad and the track connected to it, a menu will pop up to allow you to select the desired object. Select the transistor pad from the popup menu.
- 4. Position the cursor over the center of the middle transistor pad and left-click or press ENTER. Once again, select the pad from the popup menu. An information box will open showing the minimum distance between the edges of the two pads is 10.63mil.

| Information 🛛                                                                                                                          | 3 |
|----------------------------------------------------------------------------------------------------------------------------------------|---|
| Distance between<br>Pad Q1-2(2700mil, 4480mil) Multi-Layer and<br>Pad Q1-1(2750mil, 4480mil) Multi-Layer is<br>10.63mil (0.27mm)<br>OK |   |

Close the information box, then right-click or press
 ESC to exit the measurement mode and then use the V, F shortcut to re-zoom the document.

Let's look at the current clearance design rules.

 Select **Design** » **Rules** from the menus [shortcut **D**, **R**] to open the *PCB Rules and Constraints Editor* dialog. Double-click on the **Electrical** category to display all electrical rules in the right side of the dialog. Double-click on the **Clearance** type and then click on the Clearance rule to open it. The region at the bottom of the dialog will contain a single rule, specifying that the minimum clearances for the whole board are 13mil. The clearance between the transistor pads is less than this, which is why they generate a violation when we run a DRC.

We now know the minimum distance between transistor pads is a little over 10mil, so let's set up a design rule that allows the clearance constraint to be 10mil for the transistors only.

- 2. Select the **Clearance** type in the Design Rules panel, right-click and select **New Rule** to add a new clearance constraint rule.
- 3. Click on the new Clearance rule, Clearance\_1. In the **Constraints** section of the resulting page, set the **Minimum Clearance** to 10mil.
- Click on Advanced (Query) and then click on Query Helper to construct the query from the Memberships Checks. Alternatively, simply type in the following query in the Query field for the first object:

HasFootprintPad(`BCY-W3/E4','\*')

The \* (asterisk) indicates 'any pad' on the footprint named BCY-W3/E4.

- 5. Leave the scope for the second object at ALL and click **OK**. Click **Apply** and then **OK** to close the *PCB Rules and Constraints Editor* dialog.
- 6. You can now re-run the DRC from the *Design Rules Checker* dialog (**Tools** » **Design Rule Check**) by clicking the **Run Design Rule Check** button. There should be no rule violations.
- 7. Save your completed PCB and the project file.

Well done! You have completed the PCB layout and are ready to produce the output documents.

# Setting up the Project Outputs

Project outputs, such as printing and output files, are set up in Output Job files which can be copied and pasted into other projects and modified as required. Alternatively, you can select individual commands from the File menu.

- 1. Select **File** » **New** » **Output Job File**, select the output you wish to set up and double-click to modify the setups of that output. Make all necessary configurations and save the output jobs file.
- If you want the outputs to be sent to individual folders according to the output type, select Project » Project Options, click on the Options tab and click on Use separate folder for each output type and click OK.

### **Printing**

Once the layout and routing of the PCB is complete, you are ready to produce the output documentation. This documentation might include a manufacturing drawing detailing the fabrication information and assembly drawings detailing component location information and loading order.

To produce these drawings, Altium Designer includes a sophisticated printing engine that gives you complete control over the printing process. You can define precisely what mix of PCB layers you want to print, preview the drawings (called printouts) and set the scaling and orientation to see exactly how it will look on the page before you print it.

Now we will create a print preview using default output settings.

- 1. Select **File** » **Print Preview** from the PCB menus. The PCB will be analyzed and a default printout displayed in the print preview window. Click on **Close**.
- 2. Select File » Print to send the composite drawing to the printer.
- To change the target printer and set the page orientation and scaling, you can select File » Page Setup from the menus. Choose your preferred printer and check the printer page is set to Landscape. Advanced printing options are also available from this dialog.

### Manufacturing output files

The final phase of the PCB design process is to generate the manufacturing files. The set of files that are used to manufacture and fabricate the PCB include Gerber files, NC drill files, pick and place files, a bill of materials and testpoint files. Output job files can be set by selecting **File** » **New** » **Output Job File** or you can create outputs through individual commands on the **File** » **Fabrication Outputs** menu. The setups for the manufacturing documents are stored as part of the project file.

#### **Generating Gerber files**

Each Gerber file corresponds to one layer in the physical board – the component overlay, top signal layer, bottom signal layer, the solder masking layers and so on. It is advisable to consult with your PCB manufacturer to confirm their requirements before generating the Gerber and NC drill files required to fabricate your design.

To create the manufacturing files for the tutorial PCB:

1. Make the PCB the active document, then select **File** » **Fabrication Outputs** » **Gerber Files**. The *Gerber Setup* dialog displays.

If you do not want output files to automatically open when they are created, select **Project » Project Options**, click on the **Options** tab and deselect **Open Outputs after compile**.

- 2. Click on the Layers tab to select which layers to use. Click on Plot Layers and select Used On. Click OK to accept the other default settings.
- 3. The Gerber files are produced and CAMtastic opens to display the files. The Gerber files are stored in the Project Outputs folder which is automatically created in the folder where your project files reside. Each file has the file extension added that corresponds to the layer name, e.g. Multivibrator.GTO for Gerber Top Overlay. These are added to the Projects panel under Generated CAMtastic Documents.

#### **Creating a Bill of Materials**

1. To create a Bill of Materials, click on the PCB document, Multivibrator.PcbDoc and select **Reports » Bill of Materials**. The *Bill of Materials for PCB Document* dialog displays.

| Grouped Columns                               | Show                  | Description 💌                 | Designator 🛛 🔺 💌 | Footprint 💫 💌 | LibRef 💌 | Quantity 💌                                                      |
|-----------------------------------------------|-----------------------|-------------------------------|------------------|---------------|----------|-----------------------------------------------------------------|
|                                               |                       | Capacitor                     | C1               | RAD-0.1       | Сар      | 1                                                               |
|                                               |                       | Capacitor                     | C2               | RAD-0.1       | Cap      | 1                                                               |
| Other Columns                                 | Show 📥                | NPN General Purpose Amplifier | Q1               | BCY-W3/E4     | 2N3904   | 1                                                               |
| Description                                   | ✓                     | NPN General Purpose Amplifier | Q2               | BCY-W3/E4     | 2N3904   | 1                                                               |
| Designator                                    |                       | Resistor                      | R1               | AXIAL-0.3     | Res1     | 1                                                               |
| Designator-X(Mil)                             |                       | Resistor                      | R2               | AXIAL-0.3     | Res1     | 1                                                               |
| Designator-X(mm)                              |                       | Resistor                      | R3               | AXIAL-0.3     | Res1     | 1                                                               |
| Designator-Y(Mil)                             | H                     | Resistor                      | R4               | AXIAL-0.3     | Res1     | 1                                                               |
| Designator-Y(mm)                              | H                     | Header, 2-Pin                 | Y1               | HDR1X2        | Header 2 | 1                                                               |
| Document<br>Footprint<br>FootprintDescription | ✓<br>□ ✓              |                               |                  |               |          |                                                                 |
|                                               | Export<br>Eile Format | SV (Comma Delimited) (*.csv)  | ✓ □ 0pe          | n Exported    | Export   | <u>R</u> eport <u>OK</u> <u>C</u> an<br>Force Columns Into Viev |

- 2. Use this dialog to build up your BOM. Click on the **Show** checkbox next to the columns you want to add to the report.
- 3. Select and drag a column heading from Other Columns to Grouped Columns to group components by that column heading in the BOM. For example, to group by the Footprint column, select

**Footprints** in the Other Columns section and drag it into the Grouped Column section. The list will be sorted accordingly.

| Grouped Columns       | Show                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                | Description                   | Designator 🛆 💌 | Footprint 🛛 🗠 💌 | LibRef 🔹 | Quantity 💌     | •                       |
|-----------------------|-------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------|-------------------------------|----------------|-----------------|----------|----------------|-------------------------|
| Footprint             | <ul> <li>Image: A set of the set of the</li></ul> | Capacitor                     | C1, C2         | RAD-0.1         | Cap      |                | 2                       |
| h                     |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | NPN General Purpose Amplifier | Q1, Q2         | BCY-W3/E4       | 2N3904   |                | 2                       |
|                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Resistor                      | R1, R2, R3, R4 | AXIAL-0.3       | Res1     |                | 4                       |
|                       |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     | Header, 2-Pin                 | Y1             | HDR1X2          | Header 2 |                | 1                       |
|                       | Show 🔺                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                              |                               |                |                 |          |                |                         |
| Document<br>Footprint |                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                     |                               |                |                 |          |                |                         |
| C RE Hand C           | ×port                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                                               | SV (Comma Delimited) (*.csv)  |                | n Exported      | Export   | <u>R</u> eport | <u>QK</u> <u>Cancel</u> |

 Click on Report to display a print preview of your BOM. This preview can then be printed using the Print button or exported to a file format, such as .xls for Microsoft Excel, using the Export button. Close the dialogs.

Congratulations! You have completed the PCB design process.

### **Further explorations**

This tutorial has introduced you to just some of the powerful features of Altium Designer. We've captured a schematic, and designed and routed a PCB, but we've only just scratched the surface of the design power provided by Altium Designer. Once you start exploring Altium Designer, you will find a wealth of features to make your design life easier. To demonstrate the capabilities of the software, a number of example files are included. You can open these examples in the normal way by selecting **File » Open** from the menus and then navigating to the \Program Files\Altium Designer 6\Examples\ folder. As well as the board design examples in this folder, there are a number of subfolders with examples that demonstrate specific features of Altium Designer.

Check out the Circuit Simulation sub-folder to explore Altium Designer's analog and digital simulation capabilities. As well as analog examples that demonstrate various circuit designs, such as amplifiers and power supplies, there are mixed-mode examples, a math function example, and an example that includes linear and non-linear dependent sources and even a vacuum tube example.

With faster logic switching and design clock speeds, the quality of the digital signals becomes more important. Altium Designer includes a sophisticated signal integrity analysis tool that can accurately model and analyze your board layout. The signal integrity requirements such as impedance, overshoot, undershoot, and slope are defined as PCB design rules, and then tested during the standard design rule check.

If there are nets that you need to analyze in more detail, you can select **Tools** » **Signal Integrity** to pass the design to the Signal Integrity Analyzer, where you can perform reflection and cross talk simulations. The results are displayed in an oscilloscope-like waveform analyzer, where you can examine the performance and take measurements directly from the waveforms.

Thanks for participating in this introductory tutorial.

| Date        | Version No. | Revision                                                                                                                           |
|-------------|-------------|------------------------------------------------------------------------------------------------------------------------------------|
| 22-Jan-2004 | 1.0         | New product release                                                                                                                |
| 24-Nov-2004 | 1.1         | Updated for DXP 2004 SP2                                                                                                           |
| 13-Apr-2005 | 1.2         | Updated for Altium Designer                                                                                                        |
| 25-Jul-2005 | 1.3         | Reference to <i>Board Shape &amp; Sheets</i> tutorial renamed to <i>Preparing the Board for Design Transfer</i> . Updates for SP4. |
| 28-Nov-2005 | 1.4         | Updated for Altium Designer 6                                                                                                      |
| 31-Oct-2006 | 1.5         | Updated for Altium Designer 6.6                                                                                                    |

# **Revision History**

Software, hardware, documentation and related materials:

Copyright © 2005 Altium Limited.

All rights reserved. You are permitted to print this document provided that (1) the use of such is for personal use only and will not be copied or posted on any network computer or broadcast in any media and (2) no modifications of the document is made. Unauthorized duplication, in whole or part, of this document by any means, mechanical or electronic, including translation into another language, except for brief excerpts in published reviews, is prohibited without the express written permission of Altium Limited. Unauthorized duplication of this work may also be prohibited by local statute. Violators may be subject to both criminal and civil penalties, including fines and/or imprisonment. Altium, Altium Designer, CAMtastic, Design Explorer, DXP, LiveDesign, NanoBoard, Nexar, nVisage, P-CAD, Protel, Situs, TASKING and Topological Autorouting and their respective logos are trademarks or registered trademarks of Altium Limited or its subsidiaries. All other registered or unregistered trademarks referenced herein are the property of their respective owners and no trademark rights to the same are claimed.